<?php
date_default_timezone_set('PRC');
/**
*
* example目录下为简单的支付样例，仅能用于搭建快速体验微信支付使用
* 样例的作用仅限于指导如何使用sdk，在安全上面仅做了简单处理， 复制使用样例代码时请慎重
* 请勿直接直接使用样例对外提供服务
* 
**/
// 链接数据库
include_once('../include/conn_db.php');
include_once('../include/db_class.php');
mysql_connect(HOST,NAME,PASS) or die(mysql_error());
mysql_select_db(DBNAME);
mysql_query('SET NAMES '.CODEPAGE);

require_once "../lib/WxPay.Api.php";
require_once '../lib/WxPay.Notify.php';
require_once "WxPay.Config.php";
require_once 'log.php';

//初始化日志
$logHandler= new CLogFileHandler("logs/".date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);

class PayNotifyCallBack extends WxPayNotify
{
	//查询订单
	public function Queryorder($transaction_id)
	{
		$input = new WxPayOrderQuery();
		$config = new WxPayConfig();
		$input->SetTransaction_id($transaction_id);
		$input->SetSub_mch_id($config->GetSubMchId()); //设置子商户号  by vbyzc
		$result = WxPayApi::orderQuery($config, $input);
		Log::DEBUG("query:" . json_encode($result));
		if(array_key_exists("return_code", $result)
			&& array_key_exists("result_code", $result)
			&& $result["return_code"] == "SUCCESS"
			&& $result["result_code"] == "SUCCESS")
		{
			return true;
		}
		return false;
	}

	/**
	*
	* 回包前的回调方法
	* 业务可以继承该方法，打印日志方便定位
	* @param string $xmlData 返回的xml参数
	*
	**/
	public function LogAfterProcess($xmlData)
	{
		Log::DEBUG("call back， return xml:" . $xmlData);
		return;
	}
	
	//重写回调处理函数
	/**
	 * @param WxPayNotifyResults $data 回调解释出的参数
	 * @param WxPayConfigInterface $config
	 * @param string $msg 如果回调处理失败，可以将错误信息输出到该方法
	 * @return true回调出来完成不需要继续回调，false回调处理未完成需要继续回调
	 */
	public function NotifyProcess($objData, $config, &$msg)
	{
		$data = $objData->GetValues();
		//TODO 1、进行参数校验
		if(!array_key_exists("return_code", $data) 
			||(array_key_exists("return_code", $data) && $data['return_code'] != "SUCCESS")) {
			//TODO失败,不是支付成功的通知
			//如果有需要可以做失败时候的一些清理处理，并且做一些监控
			$msg = "异常异常";
			return false;
		}
		if(!array_key_exists("transaction_id", $data)){
			$msg = "输入参数不正确";
			return false;
		}

		//TODO 2、进行签名验证
		try {
			$checkResult = $objData->CheckSign($config);
			if($checkResult == false){
				//签名错误
				Log::ERROR("签名错误...");
				return false;
			}
		} catch(Exception $e) {
			Log::ERROR(json_encode($e));
		}

		//TODO 3、处理业务逻辑
		Log::DEBUG("call back JSON:" . json_encode($data));
		$notfiyOutput = array();
		/* 返回的格式 
		{
			"appid": "wxa664cef2fee1b641", //调用接口提交的公众账号ID
			"attach": "test",//附加数据，在查询API和支付通知中原样返回，该字段主要用于商户携带订单的自定义数据 （使用SetAttach设置的）
			"bank_type": "LQT",//不知什么鬼东西
			"cash_fee": "1",// 金额
			"fee_type": "CNY",//货币类型
			"is_subscribe": "N",//不知什么鬼东西
			"mch_id": "1541302151",// 商户号（服务商）
			"nonce_str": "jw0bvddz275qyvxnpdfoaam55h3dw6uk",//微信返回的随机字符串
			"openid": "opnVE5pDPx2hWAoLLxyQW5KQt8GA",// 用户openid（应该是对于绑定的公从号）
			"out_trade_no": "vbyzc_for_jstx20190701010509",// 发起订单时自定义订单号
			"result_code": "SUCCESS",// 业务结果
			"return_code": "SUCCESS",// 此字段是通信标识，非交易标识，交易是否成功需要查看result_code来判断
			"sign": "80E46C6CC50C25E6B5099AE4E03DA3C6FEFD5B172A99B03A56FAC4A9E11EC8F3",//
			"sub_mch_id": "1541763171",// 子商户id
			"time_end": "20190701090530",// 交易结束时间？？
			"total_fee": "1",// 总金额
			"trade_type": "NATIVE",// 支付方式
			"transaction_id": "4200000301201907011310094985" // 微信支付单号
		}
		*/
		//查询订单，判断订单真实性
		if(!$this->Queryorder($data["transaction_id"])){
			$msg = "订单查询失败";
			Log::DEBUG("vbyzc run to here : order querySelect faild!!!!!" );
			return false;
		}
		// 根据微信官方原代码的业务流程，应该是如下：
		// 支会成功后微信会不断请求回调，在上面的代码 应该是包函了回调回应的代码，
		// 如果成功回应，微信支付应该就停止请求回调，才能执行下面的代码 
		Log::DEBUG("vbyzc run to here :<<<<<<<<<<<<<<start to mysql record" );

        $openid = $data['openid'];// 微信用户
        $trade_no = $data['transaction_id'];// 微信支付单号
        $mch_id = $data['mch_id'];// 商户号
        $sub_mch_id = $data['sub_mch_id'];// 子商户id
		$trade_status = $data['result_code'];// 业务结果
		$total_amount = $data['total_fee'];// 总金额
		$out_trade_no = $data['out_trade_no'];// 商户自定义订单号

		$cmd = "insert into myorder(openid,trade_no,mch_id,sub_mch_id,trade_status,total_amount,out_trade_no,datetime) 
		values ('$openid','$trade_no','$mch_id','$sub_mch_id','$trade_status',$total_amount,'$out_trade_no',NOW())";
        mysql_query($cmd);
        Log::DEBUG("vbyzc run to here :end to mysql record>>>>>>>>>>" );
		return true;
	}
}

$config = new WxPayConfig();
Log::DEBUG("begin notify");
$notify = new PayNotifyCallBack();
$notify->Handle($config, false);


?>